<template>
  <div class="p-2">
    <transition :enter-active-class="proxy?.animate.searchAnimate.enter"
      :leave-active-class="proxy?.animate.searchAnimate.leave">
      <div v-show="showSearch" class="mb-[10px]">
        <el-card shadow="hover">
          <el-form ref="queryFormRef" :model="queryParams" :inline="true">
            <el-form-item label="入库时间" prop="useTime" style="width: 308px">
              <el-date-picker v-model="dateRange" value-format="YYYY-MM-DD HH:mm:ss" type="daterange"
                range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期"
                :default-time="[new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 1, 1, 23, 59, 59)]"
                style="width: 100%"></el-date-picker>
            </el-form-item>
            <el-form-item label="审批状态" prop="status">
              <el-select v-model="queryParams.status" placeholder="请选择审批状态" clearable>
                <el-option v-for="dict in approval_commit_status" :key="dict.value" :label="dict.label"
                  :value="dict.value" />
              </el-select>
            </el-form-item>
            <el-form-item label="创建时间" prop="createTime" style="width: 308px">
              <el-date-picker v-model="createTimeRange" value-format="YYYY-MM-DD HH:mm:ss" type="daterange"
                range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期"
                :default-time="[new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 1, 1, 23, 59, 59)]"
                style="width: 100%"></el-date-picker>
            </el-form-item>
            <el-form-item label="图书名称" prop="name">
              <el-input v-model="queryParams.name" placeholder="请输入图书名称" clearable />
            </el-form-item>
            <el-form-item>
              <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
              <el-button icon="Refresh" @click="resetQuery">重置</el-button>
            </el-form-item>
          </el-form>
        </el-card>
      </div>
    </transition>

    <el-card shadow="never">
      <template #header>
        <el-row :gutter="10" class="mb8">
          <el-col :span="1.5">
            <el-button type="primary" plain icon="Plus" @click="handleAdd"
              v-hasPermi="['system:admBookBorrow:add']">新增</el-button>
          </el-col>
          <el-col :span="1.5">
            <el-button type="success" plain icon="Edit" :disabled="single" @click="handleUpdate()"
              v-hasPermi="['system:admBookBorrow:edit']">修改</el-button>
          </el-col>
          <el-col :span="1.5">
            <el-button type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete()"
              v-hasPermi="['system:admBookBorrow:remove']">删除</el-button>
          </el-col>
          <el-col :span="1.5">
            <el-button type="warning" plain icon="Download" @click="handleExport"
              v-hasPermi="['system:admBookBorrow:export']">导出</el-button>
          </el-col>
          <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
        </el-row>
      </template>

      <el-table v-loading="loading" :data="admBookBorrowList" @selection-change="handleSelectionChange">
        <el-table-column type="selection" width="55" align="center" />
        <el-table-column label="主键" align="center" prop="id" v-if="false" />
        <el-table-column label="借阅人id" align="center" prop="borrowName" >
          <template #default="scope">
            <span>{{ scope.row.borrowName }}</span>
          </template>
        </el-table-column>
        <el-table-column label="部门" align="center" prop="deptId">
          <template #default="scope">
            <el-tag type="primary" disable-transitions>
              {{ scope.row.deptName }}
            </el-tag>
          </template>
        </el-table-column>
        <el-table-column label="借阅时间" align="center" prop="borrowTime" width="180">
          <template #default="scope">
            <span>{{ parseTime(scope.row.borrowTime, '{y}-{m}-{d}') }}</span>
          </template>
        </el-table-column>
        <el-table-column label="编号" align="center" prop="number" />
        <el-table-column label="图书名称" align="center" prop="name">
          <template #default="scope">
            <el-tooltip :content="scope.row.name" placement="top" :disabled="!scope.row.name">
              <div style="width: 100%; display: flex; justify-content: center; align-items: center;">
                <span
                  style="display: inline-block; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-align: center;">
                  {{ scope.row.name }}
                </span>
              </div>
            </el-tooltip>
          </template>
        </el-table-column>
        <el-table-column label="出版社" align="center" prop="bookConcern">
          <template #default="scope">
            <el-tooltip :content="scope.row.bookConcern" placement="top" :disabled="!scope.row.bookConcern">
              <div style="width: 100%; display: flex; justify-content: center; align-items: center;">
                <span
                  style="display: inline-block; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-align: center;">
                  {{ scope.row.bookConcern }}
                </span>
              </div>
            </el-tooltip>
          </template>
        </el-table-column>
        <el-table-column label="创建时间" align="center" prop="createTime" width="180">
          <template #default="scope">
            <span>{{ parseTime(scope.row.createTime, '{y}-{m}-{d}') }}</span>
          </template>
        </el-table-column>
        <el-table-column label="审批状态" align="center" prop="status">
          <template #default="scope">
            <dict-tag :options="approval_commit_status" :value="scope.row.status" />
          </template>
        </el-table-column>
        <el-table-column label="备注" align="center" prop="remark">
          <template #default="scope">
            <el-tooltip :content="scope.row.remark" placement="top" :disabled="!scope.row.remark">
              <div style="width: 100%; display: flex; justify-content: center; align-items: center;">
                <span
                  style="display: inline-block; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; text-align: center;">
                  {{ scope.row.remark }}
                </span>
              </div>
            </el-tooltip>
          </template>
        </el-table-column>
        <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
          <template #default="scope">
            <el-tooltip content="修改" placement="top">
              <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)"
                v-hasPermi="['system:admBookBorrow:edit']"></el-button>
            </el-tooltip>
            <el-tooltip content="删除" placement="top">
              <el-button link type="primary" icon="Delete" @click="handleDelete(scope.row)"
                v-hasPermi="['system:admBookBorrow:remove']"></el-button>
            </el-tooltip>
            <!-- 审批按钮 -->
            <el-tooltip content="提交审批" placement="top">
              <el-button
                link
                type="primary"
                icon="DocumentChecked"
                @click="openApprovalFlow(scope.row)"
              ></el-button>
            </el-tooltip>
          </template>
        </el-table-column>
      </el-table>

      <pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum"
        v-model:limit="queryParams.pageSize" @pagination="getList" />
    </el-card>

    <!-- 添加或修改图书入库对话框 -->
    <el-dialog v-model="dialog.visible" title="借阅图书" width="900px" append-to-body :before-close="cancel">
      <!-- 固定信息 -->
      <el-form ref="fixedFormRef" :rules="rules" :model="form" label-width="80px">
        <el-row :gutter="20">
          <el-col :span="24">
            <el-form-item label="借阅人" prop="borrowName">
              <el-input v-model="form.borrowName" disabled />
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="部门" prop="deptName">
              <el-tree-select
                v-model="form.deptName"
                :data="deptTree"
                placeholder="请选择入库部门"
                :props="{ label: 'label', value: 'id', children: 'children' }"
                check-strictly
                filterable
                :default-expand-all="true"
              />
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="借阅时间" prop="borrowTime">
              <el-date-picker
                v-model="form.borrowTime"
                type="date"
                value-format="YYYY-MM-DD"
                placeholder="请选择入库时间"
                style="width: 100%"
              />
            </el-form-item>
          </el-col>

          <!-- ✅ 选择图书按钮放在这里 -->
          <el-col :span="24">
            <el-form-item label="图书选择">
              <el-button type="primary" size="small" @click="openBookDialog()">选择图书</el-button>
            </el-form-item>
          </el-col>
        </el-row>
      </el-form>

      <!-- 图书列表 -->
      <div class="book-list">
        <el-divider></el-divider>
        <el-card v-for="(book, index) in books" :key="book.id" class="book-card" shadow="hover">
          <div style="display: flex; justify-content: space-between; align-items: center;">
            <span>图书 {{ index + 1 }}</span>
            <el-button type="danger" size="small" @click="removeBook(index)">删除</el-button>
          </div>
          <el-form :model="book" :rules="bookRules" :ref="el => setBookFormRef(el as ElFormInstance, book.id)"
            label-width="80px">
            <el-row :gutter="20" style="margin-top: 10px;">
              <el-col :span="12">
                <el-form-item label="图书名称" prop="name">
                  <el-input v-model="book.name" disabled />
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="出版社" prop="bookConcern">
                  <el-input v-model="book.bookConcern" disabled />
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="编号" prop="number">
                  <el-input v-model="book.number" disabled />
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="备注" prop="remark">
                  <el-input v-model="book.remark" placeholder="请输入备注" />
                </el-form-item>
              </el-col>
            </el-row>
          </el-form>
        </el-card>
        <div v-if="books.length === 0" class="no-book">请点击“选择图书”按钮</div>
      </div>
      <template #footer>
        <el-button @click="cancel">取消</el-button>
        <el-button type="primary" :loading="loading" @click="submitAll">提交入库</el-button>
      </template>
    </el-dialog>

    <!-- 修改图书借阅对话框 -->
    <el-dialog :title="updateDialog.title" v-model="updateDialog.visible" width="900px" append-to-body>
      <template #default>
        <el-form ref="admBookBorrowFormRef" :model="form" :rules="rules" label-width="140px" label-position="left" style="padding: 20px 0 20px 24px">
          <el-row :gutter="20">
            <el-col :span="24">
              <el-form-item label="借阅人" prop="borrowName">
                <el-input v-model="form.borrowName" placeholder="请输入借阅人" />
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="借阅部门" prop="deptName">
                <el-input v-model="form.deptName" placeholder="请选择部门" />
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="借阅时间" prop="borrowTime">
                <el-date-picker clearable v-model="form.borrowTime" type="date" value-format="YYYY-MM-DD"
                  placeholder="请选择借阅时间" style="width: 100%">
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="编号" prop="number">
                <el-input v-model="form.number" placeholder="请输入编号" />
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="图书名称" prop="name">
                <el-input v-model="form.name" placeholder="请输入图书名称" />
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="出版社" prop="bookConcern">
                <el-input v-model="form.bookConcern" placeholder="请输入出版社" />
              </el-form-item>
            </el-col>
            <el-col :span="24">
              <el-form-item label="备注" prop="remark">
                <el-input v-model="form.remark" placeholder="请输入备注" />
              </el-form-item>
            </el-col>
          </el-row>
        </el-form>
      </template>
      <template #footer>
        <div class="dialog-footer">
          <el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
          <el-button @click="updateCancel">取 消</el-button>
        </div>
      </template>
    </el-dialog>

    <!-- 选择图书对话框 -->
    <el-dialog v-model="dialogVisible" title="选择图书" width="900px" :destroy-on-close="true" :before-close="handleClose">
      <BookTreeManager ref="bookTreeRef" :books="bookList" :visible="dialogVisible" @update:visible="val => dialogVisible = val"
        @confirm="onConfirm" @cancel="dialogVisible = false" />
      <template #footer>
        <el-button @click="dialogVisible = false">取消</el-button>
        <el-button type="primary" @click="confirmSelection">确认</el-button>
      </template>
    </el-dialog>

    <!-- 审核流程配置对话框 --> 
    <ApprovalFlow v-model:visible="approvalFlowVisible" :business-type="'ADM-BOOK-BORROW-AUDIT'"
      :business-id="auditIdForApproval" :key="auditIdForApproval" title="配置图书借阅审核流程" @confirm="handleApprovalConfirm"
      @cancel="handleApprovalCancel" />
  </div>
</template>

<script setup name="AdmBookBorrow" lang="ts">
import { listAdmBookBorrow, getAdmBookBorrow, delAdmBookBorrow, addAdmBookBorrow, updateAdmBookBorrow, batchAddBooks } from '@/api/general/administration/book/borrow';
import { AdmBookBorrowVO, AdmBookBorrowQuery, AdmBookBorrowForm } from '@/api/general/administration/book/borrow/types';
import type { DeptTreeNode } from '@/api/general/administration/seal/types';
import { getDeptTree } from '@/api/general/administration/seal';
import { useUserStore } from '@/store/modules/user';
import { searchBooks } from '@/api/general/administration/book/store';
import { AdmBookStoreVO } from '@/api/general/administration/book/store/types';
import BookTreeManager from '@/components/BookTreeManager/BookTreeManager.vue'; 
import { resetApprovalStatus } from '@/components/ApprovalFlow/api';

const { proxy } = getCurrentInstance() as ComponentInternalInstance;

const admBookBorrowList = ref<AdmBookBorrowVO[]>([]);
const buttonLoading = ref(false);
const loading = ref(true);
const showSearch = ref(true);
const ids = ref<Array<string | number>>([]);
const single = ref(true);
const multiple = ref(true);
const total = ref(0);

// 用户信息
const userStore = useUserStore();

// 表单数据
const books = ref<AdmBookBorrowVO[]>([])
const bookFormRefs = ref(new Map<string, ElFormInstance | null>())

// 引入数据字典
const {  approval_commit_status } = toRefs<any>(proxy?.useDict('approval_commit_status'));

// 部门树初始化
const deptTree = ref<DeptTreeNode[]>([]);
const deptTreeSelectRef = ref();

// 图书列表初始化参数
const bookList = ref<AdmBookStoreVO[]>([]);
const dialogVisible = ref(false);
const selectedBooks = ref<{id: string|number, name: string, number: string}[]>([])
const bookTreeRef = ref<InstanceType<typeof BookTreeManager>>()

// 时间选择器查询参数初始化
const dateRange = ref<[DateModelType, DateModelType]>(['', '']);
const createTimeRange = ref<[DateModelType, DateModelType]>(['', '']);

// 当前编辑的图书索引
const currentEditIndex = ref<number | null>(null)

// 提交审核相关
const approvalFlowVisible = ref(false);
const currentSubmitAuditRow = ref<any>(null);
const auditIdForApproval = ref<string | number | undefined>(undefined);
function setBookFormRef(el: ElFormInstance | null, id: number | string) {
  const key = String(id)
  if (el) {
    bookFormRefs.value.set(key, el)
  } else {
    bookFormRefs.value.delete(key)
  }
}

const queryFormRef = ref<ElFormInstance>();
const admBookBorrowFormRef = ref<ElFormInstance>();

const dialog = reactive<DialogOption>({
  visible: false,
  title: ''
});

const updateDialog = reactive<DialogOption>({
  visible: false,
  title: ''
});

// 本地时间格式化函数
const formatLocalDate = (date = new Date()) => {
  const padZero = num => String(num).padStart(2, '0');
  return `${date.getFullYear()}-${padZero(date.getMonth() + 1)}-${padZero(date.getDate())}`;
};

const initFormData: AdmBookBorrowForm = {
  id: undefined,
  borrowId: userStore.userId,
  borrowName: userStore.name,
  deptId: userStore.deptId,
  deptName: userStore.deptName,
  borrowTime: formatLocalDate(),
  number: undefined,
  name: undefined,
  bookConcern: undefined,
  remark: undefined,
  status: undefined,
  books: [] as AdmBookBorrowVO[]
}
const data = reactive<PageData<AdmBookBorrowForm, AdmBookBorrowQuery>>({
  form: { ...initFormData },
  queryParams: {
    pageNum: 1,
    pageSize: 10,
    borrowId: undefined,
    deptId: undefined,
    borrowTime: undefined,
    number: undefined,
    name: undefined,
    bookConcern: undefined,
    status: undefined,
    createTime: undefined,
    params: {
    }
  },
  rules: {
    id: [
      { required: true, message: "主键不能为空", trigger: "blur" }
    ],
    borrowName: [
      { required: true, message: "借阅人不能为空", trigger: "blur" }
    ],
    deptName: [
      { required: true, message: "部门名称不能为空", trigger: "blur" }
    ],
    bookConcern: [
      { required: true, message: "出版社不能为空", trigger: "blur" }
    ],
    name: [
      { required: true, message: "图书名称不能为空", trigger: "blur" }
    ],
    number: [
      { required: true, message: "图书编号不能为空", trigger: "blur" }
    ],
    borrowTime: [
      { required: true, message: "借阅时间不能为空", trigger: "blur" }
    ]
  }
});

// 动态图书表单校验规则（除了备注，其他都必填）
const bookRules = {
  number: [{ required: true, message: '请输入编号', trigger: 'blur' }],
  name: [{ required: true, message: '请输入图书名称', trigger: 'blur' }],
  bookConcern: [{ required: true, message: '请输入出版社', trigger: 'blur' }],
  type: [{ required: true, message: '请选择楼层', trigger: 'change' }]
  // remark 不做校验
}

const { queryParams, form, rules } = toRefs(data);

/** 查询图书借阅列表 */
const getList = async () => {
  loading.value = true;
  try {
    const params = { ...queryParams.value };
    if (dateRange.value?.length === 2) {
      params.params = {
        ...params.params,
        bSignTime: dateRange.value[0]?.toString(),
        eSignTime: dateRange.value[1]?.toString()
      };
    }
    // 处理排序参数
    if (createTimeRange.value?.length === 2) {
      params.params = {
        ...params.params,
        beginTime: createTimeRange.value[0]?.toString(),
        endTime: createTimeRange.value[1]?.toString()
      };
    }
    const res = await listAdmBookBorrow(params);
    admBookBorrowList.value = res.rows;
    total.value = res.total;
  } catch (error) {
    console.error('获取列表失败:', error);
    proxy?.$modal.msgError('获取列表失败');
  } finally {
    loading.value = false;
  }
}

/** 取消按钮 */
const cancel = () => {
  reset();
  books.value = []
  dialog.visible = false;
}

/** 取消按钮 */
const updateCancel = () => {
  reset();
  updateDialog.visible = false;
}

/** 表单重置 */
const reset = () => {
  form.value = { ...initFormData };
  admBookBorrowFormRef.value?.resetFields();
}

/** 搜索按钮操作 */
const handleQuery = () => {
  queryParams.value.pageNum = 1;
  getList();
}

/** 重置按钮操作 */
const resetQuery = () => {
  dateRange.value = ['', ''];
  createTimeRange.value = ['', ''];
  queryFormRef.value?.resetFields();
  queryParams.value.params = {
    bUseTime: undefined,
    eUseTime: undefined,
    bBackTime: undefined,
    eBackTime: undefined,
    beginTime: undefined,
    endTime: undefined,
    params: {}
  };
  handleQuery();
}

/** 多选框选中数据 */
const handleSelectionChange = (selection: AdmBookBorrowVO[]) => {
  ids.value = selection.map(item => item.id);
  single.value = selection.length != 1;
  multiple.value = !selection.length;
}

/** 新增按钮操作 */
const handleAdd = () => {
  reset();
  dialog.visible = true;
  dialog.title = "添加图书借阅";
}

/** 修改按钮操作 */
const handleUpdate = async (row?: AdmBookBorrowVO) => {
  if(row.status != 4){
    ElMessage.error('只能对审核不通过的信息进行修改！');
    return;
  }else{
  reset();
    const _id = row?.id || ids.value[0]
    const res = await getAdmBookBorrow(_id);
    Object.assign(form.value, res.data);
    updateDialog.visible = true;
    updateDialog.title = "修改图书借阅";
  }
}

/** 提交按钮 */
const submitForm = () => {
  admBookBorrowFormRef.value?.validate(async (valid: boolean) => {
    if (valid) {
      buttonLoading.value = true;
      if (form.value.id) {
        await updateAdmBookBorrow(form.value).finally(() => buttonLoading.value = false);
        // 调用重置审核流程接口
        await resetApprovalStatus('ADM-BOOK-BORROW-AUDIT', Number(form.value.id), '不可审核')
      } else {
        // await addAdmBookBorrow(form.value).finally(() => buttonLoading.value = false);
      }
      proxy?.$modal.msgSuccess("操作成功");
      updateDialog.visible = false;
      await getList();
    }
  });
}

// 监听对话框关闭
watch(approvalFlowVisible, async (newVal, oldVal) => {
  if (oldVal && !newVal) {
    // 对话框从显示变成隐藏时刷新列表
    await getList();
  }
});

/** 删除按钮操作 */
const handleDelete = async (row?: AdmBookBorrowVO) => {
  const _ids = row?.id || ids.value;
  await proxy?.$modal.confirm('是否确认删除图书借阅编号为"' + _ids + '"的数据项？').finally(() => loading.value = false);
  await delAdmBookBorrow(_ids);
  proxy?.$modal.msgSuccess("删除成功");
  await getList();
}

/** 导出按钮操作 */
const handleExport = () => {
  proxy?.download('system/admBookBorrow/export', {
    ...queryParams.value
  }, `admBookBorrow_${new Date().getTime()}.xlsx`)
}

// 下拉框打开时展开全部节点
const handleVisibleChange = (visible: boolean) => {
  if (visible) {
    // 展开全部节点（treeSelect 内部的 tree 是 el-tree 实例）
    setTimeout(() => {
      const tree = deptTreeSelectRef.value?.$refs?.tree;
      tree?.expandAll?.();
    }, 0);
  }
};

// 获取部门树
const fetchDeptTree = async () => {
  try {
    const res = await getDeptTree();
    const processNode = (node: any) => {
      if (node.children && node.children.length > 0) {
        // 有子节点 → 禁用，但允许展开
        node.disabled = true;
        node.children.forEach(processNode); // 递归处理子节点
      } else {
        // 叶子节点 → 可选
        node.disabled = false;
      }
    };
    if (Array.isArray(res.data)) {
      res.data.forEach(processNode);
    }
    deptTree.value = res.data;
  } catch (error) {
    console.error('获取部门树失败:', error);
    proxy?.$modal.msgError('获取部门树失败');
  }
};


// 删除图书时
const removeBook = (index: number) => {
  const removedBook = books.value.splice(index, 1)[0];
}

/** 提交按钮 */
const submitAll = async () => {
  // 1) 先要有书
  if (!books.value.length) {
    ElMessage.warning('请至少添加一本图书后再提交')
    return
  }
  // 2) 校验固定表单
  if (!form.value) {
    ElMessage.error('表单未就绪，请稍后重试')
    return
  }
  // 校验每本书
  let valid = true
  for (const book of books.value) {
    const formRef = bookFormRefs.value.get(String(book.id))
    if (formRef) {
      const ok = await formRef.validate().catch(() => false)
      if (!ok) valid = false
    } else {
      valid = false
    }
  }
  if (!valid) return
  // 封装 payload
  const payload = {
    ...form.value, // 固定信息
    books: books.value // 图书数组
  }
  const res = await batchAddBooks(payload) // 调新接口
  // 触发审核流程配置对话框
  auditIdForApproval.value = res.data;
  approvalFlowVisible.value = true;
  ElMessage.success('批量入库成功')
  dialog.visible = false
  await getList();
  books.value = []
}

// 打开选择图书对话框
const openBookDialog = () => {
  dialogVisible.value = true
}

// 图书选中处理
const confirmSelection = () => {
  console.log('[父组件] 点击确认按钮')
  bookTreeRef.value?.confirmSelection()
}

// 子组件 confirm 回调
const onConfirm = (
  selected: { id: string | number; name: string; number: string; bookConcern?: string }[]
) => {
  dialogVisible.value = false
  // 过滤掉已经存在的图书，避免重复添加
  const newBooks = selected.filter(
    book => !books.value.find(b => b.id === book.id)
  ).map(book => ({
    id: book.id,
    name: book.name,
    number: book.number,
    bookConcern: book.bookConcern ?? '', // 必填字段默认空
    borrowId: '',
    borrowName: form.value.borrowName,
    deptId: form.value.deptId,
    borrowTime: form.value.borrowTime,
    remark: '',
    createTime: '',
    status: undefined
  }))
  books.value = [...books.value, ...newBooks]
}

/** 审核流程确认回调 */
const handleApprovalConfirm = async () => {
  try {
    ElMessage.success('工作日志审核流程提交成功');
    approvalFlowVisible.value = false;
    currentSubmitAuditRow.value = null;
    auditIdForApproval.value = undefined;
  } catch (error) {
    console.error('审核流程提交失败:', error);
    ElMessage.error('审核流程提交失败');
  }
};

/** 审核流程取消回调 */
const handleApprovalCancel = () => {
  approvalFlowVisible.value = false;
  currentSubmitAuditRow.value = null;
  auditIdForApproval.value = undefined;
  // 审核流程取消时，表单已经在submitCurrentWorklogs中重置了，这里不需要重复重置
};

const handleClose = () => {
  dialogVisible.value = false
};

// 打开审批弹窗
const openApprovalFlow = (row?: AdmBookStoreVO) => {
  if (row.status != 5){
    ElMessage.error('只能提交已导入的信息审批！');
    return;
  }
  auditIdForApproval.value = row.id;
  approvalFlowVisible.value = true;
};

onMounted(() => {
  getList();
  fetchDeptTree();
  searchBooks().then(res => {
    console.log('全部图书列表', res);
    bookList.value = res.data as AdmBookStoreVO[];
  });
});
</script>
